add an expansion limit for entities
authorDebian Qt/KDE Maintainers <debian-qt-kde@lists.debian.org>
Fri, 26 Jun 2020 16:47:18 +0000 (17:47 +0100)
committerDmitry Shachnev <mitya57@debian.org>
Fri, 26 Jun 2020 16:47:18 +0000 (17:47 +0100)
commitb89431ee97ee5c40937c3e449535669cb529bdc5
tree66effe21f7ccc9ed24732ea3a34de4d94b7770a5
parent574e51f3e80978fc12f3a33abea2482d487f3bf2
add an expansion limit for entities

Origin: upstream, https://code.qt.io/cgit/qt/qtbase.git/commit/?id=fd4be84d23a0db41
Last-Update: 2020-02-27

Recursively defined entities can easily exhaust all available
memory. Limit entity expansion to a default of 4096 characters to
avoid DoS attacks when a user loads untrusted content.

Added a setter and getter to allow modifying the expansion limit.

QXmlStreamReader does now by default limit the expansion of entities
to 4096 characters. Documents where a single entity expands to more
characters than the limit are not considered well formed. The limit
is there to avoid DoS attacks through recursively expanding entities
when loading untrusted content. The limit can be changed through the
QXmlStreamReader::setEntityExpansionLimit() method.

Gbp-Pq: Name CVE-2015-9541.diff
src/corelib/serialization/qxmlstream.cpp
src/corelib/serialization/qxmlstream.g
src/corelib/serialization/qxmlstream.h
src/corelib/serialization/qxmlstream_p.h